## **National University of Computer and Emerging Sciences, Lahore Campus**

| SS SO LIGHT ON INCHARLA | Course Name: | Computer Architecture | Course Code: | EE204     |
|-------------------------|--------------|-----------------------|--------------|-----------|
|                         | Program:     | BS(Computer Science)  | Semester:    | Fall 2019 |
|                         | Duration:    | 30 Minutes            | Total Marks: | 20        |
| ES BAND STILL           | Paper Date:  | 05-11-2019            | Weight       | ~3        |
| 199 MI 8 8 W.           | Exam Type:   | Quiz 3f               | Page(s):     | 2         |

| Stu  | den  | t: | Name: | Roll No |
|------|------|----|-------|---------|
| Sect | tion | :  |       |         |
| _    | •    |    |       |         |

## Question 1a [8]

What is the difference between stalling an instruction and flushing an instruction? Suppose an instruction is dependent on its previous Load instruction. What would be required in this case. Write pseudo-code to detect this hazard and then procedure to stall/flush dependent instruction.

## Question 2 [12]

Consider the following MIPS assembly language code. Assume that we run this code on the five stages pipelined data path. Division consumes 2 cycles in execution.

- 1. L1: lw R2, 50 (R4)
- 2. addi R2, R2, 4
- 3. lw R3, 150 (R4)
- 4. addi R3, R3, 8
- 5. div R5, R2, R3
- 6. sw R5, 250 (R4)
- 7. addi R4, R4, 4
- 8. bne R4, R7, L1
- a) Add stalls in the above code to remove all data and control hazards. Assume full forwarding (Exe to Exe, Mem to Exe, Exe to Dec, Mem to Mem) is implemented.

b) Rearrange the code to remove as many stalls as possible.